

//给你单链表的头指针 head 和两个整数 left 和 right ，其中 left <= right 。请你反转从位置 left 到位置 right 的链
//表节点，返回 反转后的链表 。
// 
//
// 示例 1： 
//
// 
//输入：head = [1,2,3,4,5], left = 2, right = 4
//输出：[1,4,3,2,5]
// 
//
// 示例 2： 
//
// 
//输入：head = [5], left = 1, right = 1
//输出：[5]
// 
//
// 
//
// 提示： 
//
// 
// 链表中节点数目为 n 
// 1 <= n <= 500 
// -500 <= Node.val <= 500 
// 1 <= left <= right <= n 
// 
//
// 
//
// 进阶： 你可以使用一趟扫描完成反转吗？ 
// Related Topics 链表 
// 👍 1211 👎 0


/**
 * 92.反转链表 II.reverse-linked-list-ii
 *
 * @author orz
 * @since 2022-03-23 16:28:16
 **/

class Solution_92 {
    public static void main(String[] args) {
        Solution solution = new Solution_92().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     * int val;
     * ListNode next;
     * ListNode() {}
     * ListNode(int val) { this.val = val; }
     * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
     * }
     */
    class Solution {

        /**
         * 后驱节点
         */
        private ListNode successor;

        public ListNode reverseBetween(ListNode head, int left, int right) {
            if (left == 1) {
                return reverseN(head, right);
            }
            head.next = reverseBetween(head.next, left - 1, right - 1);
            return head;
        }

        private ListNode reverseN(ListNode head, int n) {
            if (n == 1) {
                //记录第n+1个节点，最后的时候给拼接上
                successor = head.next;
                return head;
            }
            ListNode lastNode = reverseN(head.next, n - 1);
            head.next.next = head;
            head.next = successor;
            return lastNode;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}